<template>
  <PageWrapper title="导出示例" content="可以选择导出格式">
    <BasicTable title="基础表格" :columns="columns" :dataSource="data">
      <template #toolbar>
        <a-button @click="openModal"> 导出 </a-button>
      </template>
    </BasicTable>
    <ExpExcelModal @register="register" @success="defaultHeader" />
  </PageWrapper>
</template>

<script lang="ts">
import { defineComponent } from 'vue'
import { BasicTable } from '/@/vbenComponents/Table'
import { jsonToSheetXlsx, ExpExcelModal, ExportModalResult } from '/@/vbenComponents/Excel'
import { columns, data } from './data'
import { useModal } from '/@/vbenComponents/Modal'
import { PageWrapper } from '/@/vbenComponents/Page'

export default defineComponent({
  components: { BasicTable, ExpExcelModal, PageWrapper },
  setup() {
    function defaultHeader({ filename, bookType }: ExportModalResult) {
      // 默认Object.keys(data[0])作为header
      jsonToSheetXlsx({
        data,
        filename,
        write2excelOpts: {
          bookType,
        },
      })
    }
    const [register, { openModal }] = useModal()

    return {
      defaultHeader,
      columns,
      data,
      register,
      openModal,
    }
  },
})
</script>
